草庐IT

MySQL 特定的查询性能调优

全部标签

ruby-on-rails - 在 Rails 中通过 belongs_to 关系查询记录

我有一个事件模型,它们属于一个位置如何选择location.country=Australia的所有事件?(例如)我可以在一个范围内这样做吗? 最佳答案 使用最新的rails版本,您可以:Activity.joins(:location).where(locations:{country:"Australia"})注意:它是joins(:location)中的位置(单数),因为它引用了belongs_to关系名称它是where(…)中的位置(复数),因为它引用了表名后者意味着如果您有以下情况:belongs_to:location,

ruby - 思维狮身人面像未知类型 'mysql';跳绳

我使用的是ts版本2.0.5、rails3.0.9和mysql20.2.11尝试使用rakets:index创建索引时,出现以下错误:ERROR:source'technical_core_0':unknowntype'mysql';skipping.我的development.sphinx.conf包含:sourcetechnical_core_0{type=mysqlsql_host=localhostsql_user=rootsql_pass=sql_db=ps_developmentsql_sock=/tmp/mysql.socksql_query_pre=SETNAMESut

ruby - 使用 ActiveRecord 在查询对象中转义参数?

给定一个查询对象(不是AR模型)classComplexQueryQUERY=如何方便地转义所有参数?我成功地使用了三种技术,但没有一种是方便的。使用raw_connection(对我而言)返回PG::Conn的实例并调用exec_params。我对此并不满意,因为exec_params需要一组详细的参数来指定数据类型。在我的查询对象中包含ActiveRecord::Sanitization并使用其中一种方便的方法,例如replace_named_bind_variables。我对此不满意,因为replace_named_bind_variables是protected并且我必须使用s

ruby-on-rails - 在 Rails 3.1 中存储模型特定常量的最佳位置?

我在名为user的模型中有一个type字段,它是数据库中的一个int。int的值指定了它的存储类型。示例:0=妈妈1=爸爸2=祖母等等我还有其他几个这样的字段,所以创建关联表有点过分了。不是在模型和Controller逻辑的条件语句中检查那些int值,而是在Rails中有一个地方来存储这些常量。这样我就可以从我的模型和Controller中做到这一点?ifmyuser.type==MOMelsifmyuser.type==GRAND_MOTHER编辑:我最后采用的解决方案:在模型中:#constantsTYPES={:mom=>0,:dad=>1,:grandmother=>2,:gr

sql - 何时使用 ORM(Sequel、Datamapper、AR 等)与纯 SQL 进行查询

我的一位同事目前正在设计如下所示的SQL查询以生成报告,这些报告通过外部数据查询显示在excel文件中。目前只需要DB上的上报流程(无CRUD操作)。我试图说服他最好使用ruby​​ORM以便能够在rails/sinatra应用程序中显示数据。尽管在显示数据方面有明显的优势,但学习使用像Sequel或Datamapper这样的ORM对他有什么优势?他正在编写的SQL查询显然相当复杂,并且对SQL比较陌生,他经常提示它非常耗时且令人困惑。是否可以使用ORM编写极其复​​杂的查询?如果是这样,哪个最合适(我听说Sequel对遗留数据库有好处)?在进行复杂的数据库查询时,学习Ruby和使用O

ruby-on-rails - 我可以为特定资源收集路由吗?

我一直在grep搜索rakeroutes的输出,我突然意识到,一定有人知道检查路由的更好方法。我的routes.rb名称account_groups中有一个资源:resources:account_groups有没有办法告诉rakeroutes只返回与该资源关联的路由? 最佳答案 您可以检查特定Controller的路由:rake路由CONTROLLER=account_groups如@ZiiCEagle的回答所示,现在已弃用,您应该使用railsroutes-caccount_groups

ruby - 验证值是否在特定范围内,例如1 <= 值 <=2

我想验证一个数字:value在1或2之内validates:value,:format=>{:with=>/1|2/,:message=>"Selectnumber.."}但是,当value==1时,上面的代码验证失败请确保您的解决方案允许我添加验证消息。 最佳答案 validates:value,:inclusion=>{:in=>[1,2]}参见http://apidock.com/rails/ActiveModel/Validations/HelperMethods/validates_inclusion_of

ruby - 以特定顺序运行 RSpec 任务

我有一堆RSpecRake任务定义了我希望在运行整套测试时按特定顺序运行。我试过这样的:task:run_in_order=>[:one,:two,:three]doputs"Runsuiteoftests"end它运行第一个测试然后停止并且不运行其余任务。因此,如果使用Rake语法,它就不起作用。有没有办法记录RSpecRake任务的任务依赖性? 最佳答案 检查这个http://blog.davidchelimsky.net/2012/01/04/rspec-28-is-released/–orderrandWeaddedan--

ruby-on-rails - 强制 Rake 任务在特定的 Rails 环境中运行

我需要从另一个Rake任务运行一系列Rake任务。前三个任务需要在开发环境中运行,但最后一个任务需要在登台环境中运行。该任务依赖于:environment,这会导致在任务运行之前加载Rails开发环境。但是,我需要在暂存环境中执行最终任务。在调用rake任务之前传递一个RAILS_ENV=staging标志是不好的,因为此时环境已经加载,所有这一切只会设置标志,而不是加载暂存环境。有没有办法在特定环境中强制执行rake任务? 最佳答案 我以前完成过这种,尽管不是以最优雅的方式:task:preparedosystem("bundle

ruby-on-rails - 在 rails 中过滤 ActiveRecord 查询

我习惯了Django,在那里你可以在查询集上运行多个过滤方法,即Item.all.filter(foo="bar").filter(something="else")。然而,这在Rails中并不容易。Item.find(:all,:conditions=>["foo=:foo",{:foo=bar}])返回一个数组,这意味着这将不起作用:Item.find(:all,:conditions=>["foo=:foo",{:foo='bar'}]).find(:all,:conditions=>["something=:something",{:something='else'}])所以我